import nProgress from 'nprogress'
import 'nprogress/nprogress.css'
import router from '@/router'
import store from '@/store'
// 前置守卫
const whiteList = ['/login', '/404']
router.beforeEach(async(to, from, next) => {
  nProgress.start()
  // 判断是否登录
  if (store.getters.token) {
    // 登陆了
    if (to.path === '/login') {
      // 登录了还是去登录，跳转都主页，
      next('/')
      nProgress.done()// 注意这里要手动关闭进度条
    } else {
      // 登录了不去登录，放行，
      // next()
      // 登录了不去登录，判断是否有用户资料，没有就先获取
      if (!store.getters.userId) {
        await store.dispatch('user/getUserProfileAction')
      }
      next()
    }
  } else {
    // 判断是否在白名单中
    if (whiteList.includes(to.path)) {
      // 在，放行
      next()
    } else {
      // 不在，跳转到登录页
      next('/login')
      nProgress.done()// 注意这里要手动关闭进度条
    }
  }
})
// 后置守卫
router.afterEach((to, from, next) => {
  nProgress.done()
})
